IMAGE PROCESSOR 



FIELD OF THE INVENTION 

The present invention relates to an image processor 
that processes digital image data obtained, particularly, 
with a digital multifunction machine. The digital 
multifunction machine is a machine that can perform the 
functions of a copier, a facsimile, a printer, and a scanner, 
or the like. 

BACKGROUND OF THE INVENTION 

Conventionally, analog copiers were known. Recently, 
digital copiers that process digitized image data have 
appeared in the market. Further, digital multifunction 
machines that can 1 perform the functions of a facsimile, a 
printer, and a scanner in addition to the functions of the 
digital copier have also come in the market. 

Fig. 10 is a block diagram showing a hardware 
configuration of a conventional digital multifunction 
machine. This conventional digital multifunction machine 
is formed with different blocks as follows . One of the blocks 
comprises a series of components such as a scanning unit 1001 , 
an image processing unit 1002, a video control section 1003, 
and a writing unit 1004. Another block constitutes a copier 
(copier block) formed with a memory control unit 1005 and 



a memory module 1006. The rest of the blocks comprises 
additional external application units, that is, a facsimile 
control unit 1012 , a printer control unit 1013 , and a scanner 
control unit 1014 connected to the other, sections via a 
5 motherboard 1011 . Based on this configuration , the functions 
as a digital multifunction machine have been performed. 

The scanning unit 1001 scans an image to be converted 
to electric signals and outputs the signals to the image 
processing unit 1002. The writing unit 1004 reproduces the 

10 digital image signals from the video control section 1003 
onto transfer paper as a reproduction image. The image 
processing unit 1002 performs processing for image quality 
such as correction to a degraded image and reproduction of 
gradation based on area gradation on the image data scanned 

15 by the scanning unit 1001. 

The video control section 1003 performs controls for 
the bus. More specifically, the video control section 1003 
controls input signals from the image processing unit 1002, 
output signals to the writing unit 1004 , input/output signals 

20 to/from the memory control unit 1005 , and input/output signals 
to/from the external application unit via the motherboard 
1011. 

The external application unit is connected to the other 
sections via the motherboard 1011, each> of the application 
25 units functions as a discrete unit, and each unit has its 
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own CPU and memory. 

That is, in the copier block which performs the functions 
as a copier, a sequence of operations of the components such 
as the scanning unit 1001, the image processing unit 1002, 
5 the video control section 1003, and the writing unit 1004 
are controlled by a system controller 1007, RAM 1008, and 
ROM 1009. While each of the units such as the facsimile 
control unit 1012, the printer control unit 1013, and the 
scanner control unit 1014 performs its functions by utilizing 
10 a part of the sequence of the operations established in the 
copier . 

As a copier , for example , a j ob , that utilizes the memory 
module 1006 for image rotation and so on, is performed by 
storing image data in the memory module 1006 through the video 

15 control section 1003 and the memory control unit 1005 from 
the image processing unit 1002, performing the processing 
for image rotation, and reproducing the image via the video 
control section 1003 and the writing unit 1004 , The sequence 
of these controls are performed in the system controller 1007 . 

20 On the other hand, the processing for bitmapping an 

image to be printed out in the printer control unit 1013 is 
not executed by the system controller 1007 and the memory 
control unit 1005 , but CPU andmemory , not shown, specifically 
provided in the printer control unit 1013 are used for the 

25 processing. 
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In other words, the functions of the digital 
multifunction machine are performed by adding the facsimile 
control unit 1.012, the printer control unit 1013, and the 
scanner control unit 1014 on to the copier block established 
5 as one system with the series of components. This is based 
on the background that importance is placed on a processing 
speed, that is , the processing should be speeded up by forming 
the series of components with hardware such as ASIC 
(Application Specific Integrated Circuit) . 
2 10 Further, there is know an image processor (e.g., see 

fy Japanese patent application laid open HEI 08-274986A) which 

Lfl optimizes image processing of scanned signals, storage of 

y3 images to memory, parallel operation of a plurality of 

H 8 functions , and image processing of the respective operations . 

» 15 This is one of the apparatuses in which the various types 

of image processing can be executed by one configuration for 
image processing. 

Thus , the copier block has been established as one system 
in the conventional digital multifunction machine. 
20 Therefore, each of the units connected to the copier block 
such as the facsimile control unit 1012, the printer control 
unit 1013, and the scanner control unit 1014 has to construct 
its own system separately from the copier block in order to 
perform each of their functions. 
25 Accordingly, a memory module, a control module, and 



a memory control module required for performing the functions 
of each of the units need to be provided in each of the units. 

Therefore, the units can not make effective use of the 
memory module 1006 provided in the copier block, but also 
provision of plural memory modules for the respective units 
has led to increased size as an overall apparatus and also 
increased cost. 

When a conflict occurs between a request for processing 
from the add-on facsimile control unit 1012 or printer control 
unit 1013 and a request for processing from the scanning unit 
1001, the system controller 1007, that has been designed 
around a copying function section, controls the overall 
apparatus, therefore, the most appropriate image processing 
as the overall apparatus can not always be performed. 

For example, once facsimile reception is started in 
the facsimile control unit 1012, the copy of a document can 
not be obtained until the facsimile reception is finished 
even if a few sheets of document are to be copied. That is, 
in the conventional art, a control mechanism that optimizes 
performance as an overall system and integrally controls the 
units has been missing. 

Likewise, since the copier block has been established 
as one system, the functions of the copier block can not 
efficiently be improved in association with improved 
performance of peripheral units. For example, when only the 



scanning unit 1001 or the writing unit 1004 is altered, more 
specifically, when 400 dpi provided in the scanning unit 1001 
or the writing unit 1004 is to be altered to 600 dpi, the 
functions of the overall apparatus have not easily been 
improved by the work only to replace the unit. 

That is , a series of systems as the overall copier block 
have already been established so as to scan or write data 
by 400 dpi. Therefore, when the unit is to be replaced, a 
matrix size and threshold values or the like for intermediate 
processing are required to be changed. With regard to the 
other units, their setting contents may also be changed so 
as to enable scanning or writing of data by 600 dpi. 

Accordingly, when the system is configured with the 
hardware such as ASIC, the hardware itself (custom-built IC 
and LSI) has to be replaced. Therefore, it is impossible 
to easily improve the functions of the overall apparatus in 
association with improved performance of the peripheral units 
only by replacing the peripheral units. 

These problems may come up not only in the case of 
peripheral units but also in the case where improvement in 
functions such as operability of the digital multifunction 
machine is intended. That is, in order to improve functions 
of the digital multifunction machine, the work such that 
alteration has to be performed over the whole contents of 
the system is required. Therefore, it is quite impossible 
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for designers to improve the functions of the digital 
multifunction machine in a simple manner. Further, the 
latest algorithm can not easily be provided to users to utilize 
the digital multifunction machine. 
5 Further, since the sections forming the copier are 

established as one system, when the digital multifunction 
machine is made use of as a scanner or a printer as a single 
unit, the functions can not easily be separated from each 
other . 

10 As explained above, in the conventional digital 

fU multifunction machine, there has been such a problem that 

LH the most appropriate control mechanism is not constructed 

43 in the following point of making effective use of resources 

j** in the system such as sharing of the module, improvement of 

Jif 15 the function by replacement for each unit, and division of 

J? the function into a plurality of functions. Especially, 

IssJ 

there has been desired an image processor in which controls 
provided for input/output of data in/from image memory, that 
is most frequently used in the digital multifunction machine , 
20 are well linked to controls provided for the units. 



SUMMARY OF THE INVENTION 

It is an object of this invention to provide an image 
processor which makes effective use of resources in a system 
25 for performing multifunction and allows optimal controls as 
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the overall system. 

The image processor according to the present invention 
integrally manages the overall system and can share the memory 
group with the units without occurrence of a conflict between 
them. Accordingly, it is possible to make effective use of 
resources in the system when multifunction is performed and 
provide optimal controls as an overall system. 

Other obj ects and features of this invention will become 
apparent from the following description with reference to 
the accompanying drawings . 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram that shows a functional 
configuration of the image processor according to an 
embodiment of this invention; 

Fig. 2 is a block diagram that shows an example of a 
hardware configuration of the image processor of this 
invention ; 

Fig. 3 is a block diagram that shows a configuration 
of a controller unit that controls the system and the memory 
of the image processor of this invention; 

Fig. 4 is a block diagram showing various controls in 
an image-memory access control section of the image processor 
of this invention; 

Fig. 5 is a block diagram showing an example of a basic 

8 



configuration of system controls and bus connections in the 
image processor of this invention; 

Fig. 6 is a block diagram showing an example of a control 
system in a discrete printer; 

Fig. 7 is a block diagram showing an example of controls 
of the image processor that performs multifunctional image 
processing ; 

Fig. 8A and Fig. 8B are block diagrams showing outlines 
of compression/expansion of image data in a 
compression/expansion module ; 

Fig . 9 is a block diagram schematically showing a memory 
control section of this invention; and 

Fig. 10 is a block diagram showing a hardware 
configuration of a conventional digital multifunction 
machine . 

DESCRIPTION OF THE PREFERRED. EMBODIMENTS 

Apref erred embodiment of the image processor according 
to this invention will be explained in detail below with 
reference to the attached drawings . 

Principles of the image processor of this embodiment 
will be explained first. Fig. 1 is a block diagram 
functionally showing a configuration of the image processor 
according to the embodiment of this invention. As shown in 
Fig. 1, the image processor comprises five units as follows. 



The five units are an image data control unit 100, an 
image reading unit 101 that reads image data, an image memory 
control unit 102 that controls image memory for accumulating 
images to execute writing/reading of image data in/from the 
5 image memory, an image processing unit 103 that subjects the 
image data to imaging such as processing and editing, and 
an image writing unit 104 that writes the image data onto 
transfer paper or the like. 

The units, that is, the image reading unit 101, the 
d3 10 image memory control unit 102 , the image processing unit 103 , 

FU and the image writing unit 104 are provided around and 

w connected to the image data control unit 100, respectively. 

; : : 

J3 Image data control unit 100 : 

The processing executed by the image data control unit 
15 100 includes those as follows. For example: 

(1) Data compression to improve data transfer efficiency 
on the bus (Primary compression) 

(2) Transfer of the primarily compressed data to image data 

(3) Image synthesis (Image data from a plurality of units 
20 can be synthesized. Further, the synthesis includes image 

synthesis on the data bus.) 

(4) Image shift ( Shift of an image in a main scanning direction 
and an auxiliary scanning direction) 

(5) Expansion of an image area (Image area can be expanded 
25 to its periphery by an arbitrary amount.) 



(6) Image scaling (Fixed scaling of 50% or 200%, for example) 

(7) Parallel bus/ interface processing 

(8) Serial bus/ interface processing (Interface to a process 
controller 211 explained later) 

(9) Format conversion between parallel data and serial data 
(11) Interface processing to the image reading unit 101 

. (12) Interface processing to the image processing unit 103 
Image reading unit 101: 

The processing executed by the image reading unit 101 
includes those as follows. For example: 

(1) Scanning light reflected off a document by an optical 
system 

(2) Conversion of data to electric signals in CCD (Charge 
Coupled Device) 

(3) Digitization in the A/D converter 

(4) Shading correction (Correction to nonunif ormity in 
illumination distribution of a light source) 

(5) Scanner a-correction (Correction to density 
characteristics in the scanning system) 

Image memory control unit 102: 

The processing executed by the image memory control 
unit 102 includes those as follows. For example: 

(1) Interface control to the system controller 

(2) Parallel bus control (Interface control to the parallel 
bus ) 
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(3) Network control (Control for data for a printout request 
that is input via a network) 

(4) Serial bus control (Control for a plurality of external 
serial ports) 

(5) Internal bus interface control (Control for commands 
with the operation section) 

(6) Local bus control (Control for access to ROM, RAM, and 
font data to start up the system controller) 

(7) Operation control for image memory (memory group) 
(Write/read controls in/from the memory group, or the like) 

(8) Control for access to the memory group (Processing for 
controllingmemory-access requests from a plurality of units ) 

(9) Data compression/expansion (Processing for reducing 
data amounts to effectively utilize the memory) 

(10) Image editing (Clearing of data in a memory area, 
rotation of image data, and image synthesis on the memory, 
or the like) 

Image processing unit 103: 

The processing executed by the image processing unit 
103 includes those as follows. For example: 

(1) Shading correction (Correction to nonunif ormity in 
illumination distribution of the light source) 

(2) Scanner a-correction (Correction to density 
characteristics in the scanning system) 

(3) MTF correction 



(4) Smoothing 

(5) Scaling to an arbitrary size in the main scanning 
direction 

(6) Density conversion ( y conversion: corresponding to a 
density notch) 

(7) Simple multi-valued processing 

(8) Simple binary processing 

(9) Error diffusion 

(10) Dithering 

(11) Phase control for dot arrangement (dots aligned on the 
right, dots aligned on the left) 

(12) Removal of isolated points 

(13) Separation of image area (Determination of color, 
determination of an attribute, processing for adaptation) 

(14) Density conversion 
Image writing unit 104: 

The processing executed by the image writing unit 104 
includes those as follows. For example: 

(1) Edge smoothing (Jaggy correction) 

(2) Correction for re-arrangement of dots 

(3) Pulse control for image signals 

(4) Format conversion between parallel data and serial data 
Hardware configuration of digital multifunction machine: 

The configuration of hardware when the image processor 
according to this embodiment forms a digital multifunction 



machine is explained below. Fig. 2 isablock diagram showing 
an example of the configuration of the hardware in the image 
processor according to this embodiment. 

As shown in the block diagram of Fig. 2, the image 
processor according to this embodiment comprises a scanning 
unit 201 , a sensor board unit 2 02 , an image data control section 
203, an image processor 204 f a video data control section 
205, and an image formation unit (engine) 206. The image 
processor according to this embodiment J also comprises a 
process controller 211, RAM 212, and ROM 213 via a serial 
bus 210. 

The image processor according to the embodiment further 
comprises an image-memory access control section 221, and 
a facsimile control unit 224 via a parallel bus 220 , and further , 
a memory group 222, a system controller 231, RAM 232, ROM 
233 , an operation panel 234 , font data ROM 235 , and an external 
serial port 236,, which are connected to the image-memory 
access control section 221. 

A relation between the components and the respective 
units 100 to 104 as shown in Fig. 1 is explained below. That 
is, the function of the image reading unit 101 shown in Fig. 
1 is performed by the scanning unit 201 and the sensor board 
unit 202. The function of the image data control unit 100 
is performed by the image data control section 203 . Further , 
the function of the image processing unit 103 is performed 



by the image processor 204. 

The image writing unit 104 is formed with the video 
data control section 205 and the image formation unit (engine) 
206. Likewise, the image memory control unit 102 is formed 
with the image-memory access control section 221 and the 
memory group 222 . 

The contents of each component is explained below . The 
scanning unit 201 , that optically scans a document , comprises 
a lamp, a mirror, and a lens. Reflection light of the light 
irradiated from the lamp to the document is converged to a 
photoreceptor through the mirror and the lens. 

The photoreceptor such as a CCD is mounted on the sensor 
board unit 202 . The image data converted to electric signals 
in the CCD is converted to digital signals, and is output 
(transmitted) from the sensor board unit 202. 

The image data output (transmitted) from the sensor 
board unit 202 is input (received) into the image data control 
section 203. Transmission of the image data between 
functional devices (processing units) and data buses are 
controlled in the image data control section 203. 

The image data control section 203 performs data 
transfer for image data between the sensor board unit 202, 
the parallel bus 220, and the image processor 204, and also 
performs communications for image data between the process 
controller 211 and the system controller 231 that controls 



the overall image processor. The RAM 212 is used as a work 
area of the process controller 211, and the ROM 213 stores 
a boot program or the like of the process controller 211. 

The image data output (transmitted) from the sensor 
5 board unit 202 is transferred (transmitted) to the image 
processor 204 through the image data control section 203. 
Signal degradation (signal degradation in the scanner system) 
due to the optical system and quantization of the image data 
to digital signals is corrected, and the corrected signals 
10 are again output (transmitted) to the image data control 
section 203 . 

The image-memory access control section 221 controls 
writing and reading of the image data in and from the memory 
group 222. The image-memory access control section 221 also 

15 controls operations of the respective components connected 
to the parallel bus 220. The RAM 232 is used as a work area 
of the system controller 231, and the ROM 233 stores a boot 
program or the like of the system controller 231. 

The processing that has to be done by the image processor 

20 is entered through the operation panel 234. For example, 
a type of processing (copying, facsimile transmission , image 
scanning, or printing) and a quantity of copies to be processed 
are entered through the operation panel 234. Accordingly, 
control information for the image data can be input. 

25 . There are two jobs related to the scanned image data: 
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a job that accumulates the data in the memory group 222 and 
reuses it, and a job that does not accumulate the data in 
the memory group 222. The respective cases are explained 
below. As an example of accumulating the scanned image data 
in the memory group 222, when a plurality copies of a sheet 
of document are to be made, there is a method for allowing 
the scanning unit 201 to operate only once, accumulating the 
image data scanned by the scanning unit 201 in the memory 
group 222, and reading out the accumulated image data a 
plurality of times. 

As an example of not using the memory group 222, when 
only a copy of a sheet of document is to be made, the scanned 
image data may be reproduced as it is. Therefore, there is 
no need for the image-memory access control section 221 to 
access the memory group 222. 

When the memory group 222 is not used, the data 
transferred from the image processor 204 to the image data 
control section 203 is returned again from the image data 
control section 203 to the image processor 204. The image 
processor 204 performs the processing for image quality to 
convert the brightness data obtained by the CCD in the sensor 
board unit 202 to area gradation. 

The image data whose image quality has been processed 
is transferred from the image processor 204 to the video data 
control section 205. The video data control section 205 



provides pulse controls for the signals converted to the area 
gradation in order to perform post-processing for dot 
arrangement and reproduce the dots . A reproduction image 
is then formed on the transfer paper in the image formation 
5 unit 206. 

A flow of image data is explained below. More 
specifically, the flow of image data shows the case where 
image data is accumulated in the memory group 222 and 
additional processing, such as rotation of an image direction 
y5 10 or synthesis of images, is performed at the time of reading 

fU out the images. The image data transferred from the image 

j£ji processor 204 to the image data control section 203 is sent 

^ from the image data control section 203 to the image-memory 

r7 access control section 221 through the parallel bus 220. 

™ 15 The image-memory access control section 221 provides 

S controls, under the control of the system controller 231, 

for accesses to the image data and the memory group 222 , and 
performs bitmapping of print data for an external PC (personal 
computer) 223 , and compression or expansion on the image data 
20 to make effective use of the memory group 222. 

The image data sent to the image-memory access control 
section 221 is compressed as required and then accumulated 
in the memory group 222. The accumulated image data is read 
out as required. The read-out image data is decompressed 
25 and restored to the original image data, and the restored 



data is returned from the image-memory access control section 
221 to the image data control section 203 through the parallel 
bus 220. The processing in the image-memory access control 
section 221 will be explained in detail later. 

The image data is transferred from the image data control 
section 203 to the image processor 204, subjected to 
processing for image quality, and is pulse-controlled in the 
video data control section 205 to form a reproduction image 
on transfer paper in the image formation unit 206. 

In the flow of the image data, the functions of the 
digital multifunction machine are performed through the 
parallel bus 220 and based on bus control provided by the 
image data control section 203. The function of facsimile 
transmission is performed by executing image processing on 
the read-out image data in the image processor 204 and 
transferring the image data to the facsimile control unit 
224 through the image data control section 203 and the parallel 
bus 220. The facsimile control unit 224 converts the data 
to that for a communication network and transmits the 
converted data as facsimile data to a telephone network (PN) 
225. 

As for the received facsimile data, on the other hand, 
the data for a network from the telephone network (PN) 225 
is converted to image data in the facsimile control unit 224 
and transferred to the image processor 204 through the 



parallel bus 220 and the image data control section 203. In 
this case, specific processing for image quality is not 
performed on the data, but the video data control section 
205 performs re-arrangement of dots and pulse controls, and 
5 the image formation unit 206 forms a reproduction image on 
transfer paper. 

Under the situation that the plurality of jobs, such 
as a copying function, a facsimile transmission/ reception 
function, and a print-out function, operate in parallel, the 

10 system controller 231 and the process controller 211 provide 
controls for allocation of accesses by the scanning unit 201 , 
the image formation unit 206, and the parallel bus 220 to 
the respective jobs. 

The system controller 231 controls the overall system 

15 and manages to start up its resources, while the process 
controller 211 controls the flow of image data under the 
control of the system controller 231. Selection of the 
functions of the digital multifunction machine is executed 
in the operation panel (operation section) 234 to set contents 

20 of processing for the copying function or the facsimile 
function . 

The system controller 231 and the process controller 
211 perform interactive communications through the parallel 
bus 220, the image data control section 203, and the serial 
25 bus 210. More specifically, communications between the 




system controller 231 and the process controller 211 are 
performed by converting data formats to each other for 
respective data interfaces to the parallel bus 220 and the 
serial bus 210 in the image data control section 203. 
5 A relation between controls for the overall image 

processor and the memory group 222 shared with the units and 
the control sections will be explained below. Fig. 3 is a 
block diagram showing a configuration of a controller unit 
that controls the system and the memory. A controller unit 
i£j 10 301 is formed by integrating the system controller 231 that 

fU controls operation of the overall image processor, the memory 

yn group 222, the image-memory access control section 221, and 

. various types of bus interfaces into one module. 

H" The controller unit 301 is connected to relating units , 

ra=== 

z? 15 that is, the image data control unit 100 , the image reading 

3 unit 101 , the image processing unit 103 , and the image writing 

unit 104 via a plurality types of buses in order to keep its 
independence in the whole image processor. The system 
controller 231 outputs a control signal required for 
20 controlling each functional unit to the unit via the parallel 
bus 220. The parallel bus 220 is used for transfer of image 
data other than control signals. 

More specifically, in the controller unit 301, the 
system controller 231 outputs a control signal used for 
25 controlling operation of each functional unit to the image 



data control section 203 through the image-memory access 
control section 221 , a parallel bus I/F 302 , and the parallel 
bus 220 . The controller unit 301 receives , under the control 
of the image-memory access control section 221, image data 
from the image data control section 203, and stores the data 
in the memory group 222 through the parallel bus 220, the 
parallel bus I/F 302, and the image-memory access control 
section 221. 

On the other hand, when data for printing is sent out 
from a PC (personal computer) 223, the controller unit 301 
provides controls for a network 306 with a printer controller 
(not shown) and also controls for a serial bus 307. 

Specifically, when data for a printout request is input 
over the network 306, the controller unit 301 receives the 
data in the image-memory access control section 221 via a 
network I/F 303. When bypassing the network 306 and being 
connected to a general-purpose serial bus 307 , the controller 
unit 301 also receives the printout request data in the 
image-memory access control section 221 through the serial 
bus I/F 304. The serial bus I/F 304 includes a plurality 
types of I/F such as interfaces for USB, 1284, and 1394. 

The printout request data received through the network 
I/F 303 or the serial bus I/F 304 is bitmapped to image data 
by the system controller 231. An area for bitmapping is a 
predetermined area in the memory group 222, and font data 



required for the bitmapping is referred to and acquired from 
the font data ROM 235 by a local bus I/F 305 through a local 
bus 237. 

The serial bus 307 also includes an I/F for connection 
with the operation panel 234 of the image processor other 
than an I/F connected to the external serial port 236 that 
is used for connection with a PC different from the PC 223. 
This I/F is not used for transmission or reception of the 
bitmapped data for printing, but is used for communications 
with the system controller 231 through the image-memory access 
control section 221 to accept a sequence of processing and 
display the system status and so on. 

The local bus 237 interfaces to the ROM 232 and the 
RAM 233 required for controlling the controller unit 3 01 other 
than the font data ROM 235. 

The interface (transmission or reception of image data 
and control signals) between the system controller 231, the 
memory group 2 22 , and various types of bus is performed through 
the image-memory access control section 221, and the jobs 
using the memory group 222 are integrally managed in the whole 
image processor. The system controller 231 that controls 
the whole apparatus is provided in the controller unit 301, 
therefore, when performance related to data access in the 
image processor is to be altered, the alteration can be 
executed only by replacing the controller unit 301. 



The units can be adapted to respective performance. 
More specifically, by controlling performance of the system 
controller 231 as a single unit, and a memory capacity of 
and an access speed to the memory group 222, a unit most 
appropriate for both the cost and the performance required 
in the image processor can be formed* 

For example, when the resolution of the scanning unit 
201 is increased and the amount of image data becomes large, 
by .controlling accesses to the memory group 222 , the image 
processor may be allowed to deliver optimal performance as 
a whole . Alternatively , the controller unit may be exchanged 
to a controller unit 301 with increased capacity of the memory 
group 222 as required. 

The functions of the image-memory access control 
section 221 will be explained below . Fig. 4 is ablock diagram 
showing various controls provided by the image-memory access 
control section . Instructions and data transactions between 
the image-memory access control section 221 and the system 
controller 231 are performed via a system I/F 401. 

Basically, the system controller 231 controls the 
overall apparatus and also manages allocation of the resources 
of the memory group 222. With regard to controls for the 
units other than the image-memory access control section 221 , 
by transmitting or receiving various instructions and data 
(control signals) through the system I/F 401, the parallel 



bus control section 402 , and the parallel bus 220 , operations 
of the units are controlled. 

Connection between the image-memory access control 
section 221 and the parallel bus 220 is executed under the 
control of the parallel bus control section 402 . The parallel 
bus control section 402 provides controls so that the bus 
is not occupied because the units of the image processor are 
basically connected to the parallel bus 220. Accordingly, 
the parallel bus control section 4 02 manages data transmission 
or reception to or from the system controller 231 and the 
memory group 222. 

Connection between the image-memory access control 
section 221 and the network 306 (e.g., LAN: Local Network 
Area) is executed under the control of a network control 
section 403. The network control section 403 manages to 
transmit or receive data to or from externally extended 
equipment (connected equipment) connected to a network via 
the network 306. The system controller 231 does not manage 
the operation itself in the connected equipment on the network 
306, but provides controls for the interface in the 
image-memory access control sect ion 221. In this embodiment , 
control for 100Base-T is added. 

Connection between the image-memory access control 
section 221 and the serial bus 307 is executed by a serial 
port 404 under the control of a serial port control section 



405. The serial port 404 has port control mechanisms 
corresponding to the number of types of bus. In this 
embodiment, the serial port control section 405 provides 
port-controls for USB, IEEE 1284 , or the like. The serial 
port control section 405 , separately from the external serial 
port 236, provides controls for acceptance of commands or 
data-transmission or reception related to display with the 
operation panel 234. 

Connection between the image-memory access control 
section 22 1 and the local serial bus (localbus) 237 is executed 
under the control of a local bus control section 406. More 
specifically, the local bus control section 406 interfaces 
with the local bus 237 connected to the RAM 232 and the ROM 
233 required for starting the system controller 231, and the 
font data ROM 235 with which printer code data is bitmapped. 
Further, connection between the image-memory access control 
section 221 and the memory group 222 is executed under the 
control of a memory control section 407 . 

Controls for storage of image data input into the 
image-memory access control section 221 in the memory group 
222 will be explained below . The image data transmitted from 
the image data control section 203 is input into the 
image-memory access control section 221 by the parallel bus 
control section 402 via the parallel bus 220 . The image data 
is then off the management of the system controller 231 in 




a DMAC (Direct Memory Access Control section ) 408, and is 
handled discretely from the control of the system. 

When image data is to be stored in the memory group 
222 , accesses to the memory group 222 may concurrently occur . 
5 An access control section 409 controls, under the control 
of the system controller 23 1 f access requests from a plurality 
of units , and the memory control section 407 provides controls 
for access , operations to the memory group 222 and 
reading/writing data from/in the memory group 222. 

10 The same goes for access from the network 306 to the 

memory group 222 . The image data input into the image-memory 
access control section 221 by the network control section 
403 is stored (access) to the memory group 222 through a DMAC 
410 . When a plurality of j obs related to storage concurrently 

15 occur, the access control section 409 controls accesses to 
the memory group 222, and the memory control section 407 
performs read/write of image data. 

The same goes for access from the serial bus 307 to 
the memory group 222 . The image data input into the 

20 image-memory access control section 221 by the serial port 
control section 405 is stored (access) to the memory group 
222 through a DMAC 411. When a plurality of jobs related 
to storage concurrently occur, the access control section 
409 controls accesses to the memory group 222 , and the memory 

25 control section 407 performs read/write of data. 



Printout data through the network 306 or the serial 
bus 307 from a PC 233 is bitmapped in a memory area of the 
memory group 222 by the system controller 231 using the font 
data ROM 235 on the local bus 237. 

Interfaces with the external units are managed by the 
system controller 231 , and the respective DMACs manage memory 
accesses . In this case , each of the DMACs discretely executes 
data transfer f therefore , the access control section 4 09 gives 
priorities to jobs related to accesses to the memory group 
222 when a collision occurs between the jobs, or to access 
requests as explained above. 

The access to the memory group 222 includes an access 
from the system controller 231 via the system I/F 401 other 
than each DMAC in order to bitmap the stored data. The image 
data from any DMAC that is permitted to get access to the 
memory group 222 in the access control section 409 or the 
image data from the system I/F 401 is directly stored in the 
memory group 222 under the control of the memory control 
section 407 . 

The image-memory access control section 221 further 
comprises a compression/expansion module 412 and an image 
edit module 413 , and performs processing and editing on image 
data. The compression/expansion module 412 compresses or 
decompresses data so as to enable effective accumulation of 
image data or code data in the memory group 222 , and its 
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interface with the memory group 222 is controlled by a DMAC 
414 . 

For example, when image data is to be decompressed, 
the DMAC 414 reads image data once stored in the memory group 
5 2 22 and transmits the data to the compress ion/ expans ion module 
412 via the memory control section 407 and the access control 
section 409. The compression/expansion module 412 

decompresses the image data and, under the control of the 
DMAC 414, transmits the data to the memory group 222 or 
«0 10 transmits (outputs) the data to the external bus . When image 

rU data is to be compressed, the compression/expansion module 

^= 412 compresses image data. The operation of the 

"~ compression/expansion module 412 will be explained later. 

[T The image edit module 413 controls the memory group 

S 15 222 by a DMAC 415, and performs data processing in an area 

R of the memory group 222. For example, processing such as 

clearing of a memory area, rotation of image data, synthesis 
of different images is executed. Further, target data to 
be processed is converted by controlling it's address on the 
20 memory group 222 at the time of editing the image. However, 
the compressed image data can not directly be converted to 
code data or printer code data. Therefore, a sequence of 
performing processing on the bitmapped image on the memory 
group 222 is required. In order to make effective use of 
25 the memory group 222, compression is subjected as required 



to the data after image is edited and the compressed data 
is stored in the memory group 222. 

A relation between system controls and bus connections 
in the image processor will be explained below. Fig. 5 is 
5 a block diagram showing an example of a basic configuration 
of system controls and bus connections in the image processor 
according to this embodiment. The image-memory access 
control section 221 , the image data control section 203, and 
the video data control section 205 are connected to the 

O 

J3 io parallel bus 220, and data transfer is performed between the 

Ty units via the parallel bus 220. Image data and command code 

jfj are transferred in a predetermined format on the parallel 

^ bus 220 regardless of its type. 

jT Although the apparatus as a whole is controlled by the 

S 15 system controller 231, the units other than the memory group 

S 222 and the parallel bus 220 are directly controlled by the 

process controller 211. That is, the system controller 231 
controls the process controller 211, and controls the units 
via the process controller 211 . A relation between the system 
20 controller 231 and the process controller 211 represents a 
relation between a master and a slave, and communications 
are performed between the controllers. 

Format conversion between parallel data and serial data 
is performed in the image data control section 203 or the 
25 video data control section 205 as explained above . A control 



signal from the system controller 231 is transmitted to the 
parallel bus 220 via the parallel bus control section 402 
in the image-memory access control section 221 . This control 
signal is input into the image data control section 203, 
converted to from parallel data to serial data, and the serial 
data is transferred to the serial bus 307. 

The process controller 211 receives the control signal 
sent by the system controller 231 via the serial bus 307. 
The process controller 211 then controls the image data 
control section 203 and the video data control section 205 
via the serial bus 307 according to the instruction. While 
the process controller 211 is controlling the image data 
control section 203 and the video data control section 205, 
the system controller 231 provides system controls separately 
from the process controller 211 . Accordingly , it is possible 
to improve performance in the various processing of the image 
processor . 

Fig . 6 is a block diagram showing an example of a control 
system in a discrete printer. As compared to the image 
processor shown in Fig. 5, this discrete printer has the same 
configuration formed with the system controller 231, the 
image-memory access control section 221, and the parallel 
bus 220 to which the two units are connected, but does not 
require the image data control section 203 for a scanner 
processing system. 



Image data for printout (data for printing) is input 
from the PC 223 via the network 306 or the general-purpose 
serial bus 307 , bitmapped, and the bitmapped image is 
transferred from the image-memory access control section 221 
to the video data control section 205 through the parallel 
bus 220. 

A control signal for the video data control section 
205 is transferred from the system controller 231 to the video 
data control section 205 through the image-memory access 
control section 221. In the video data control section 205 , 
the control signal is converted to serial data and transferred 
to the process controller 211 through the serial bus. The 
process controller 211 controls writing in the image formation 
unit 206 based on this control signal. 

Fig. 7 is a block diagram showing an example of controls 
of the image processor that performs multifunctional image 
processing. The image processor uses a dedicated data path 
for data transfer from the image data control section 203 
to the video data control section 205 bypassing the parallel 
bus 220. Accordingly, it is possible to make effective use 
of the parallel bus 220 and improve performance of the system. 

More specifically , processing performance of the image 
processor is enhanced by sharing the processing with the 
system controller 231 and the process controller 211. That 
is, the process controller 211 provides controls for writing 




performed mainly in the image writing unit 104 and also 
controls for image processing by playing a role as a 
coprocessor of the system controller 231. 

The operation of the compression/expansion module 412 
5 will be explained below. Fig. 8A and Fig. 8B are block 
diagrams showing outlines of compression/expansion of image 
data. Fig. 8A shows a path for image data when the image 
data is compressed (coded) , and Fig. 8B shows a path for image 
data when the coded data (compressed image data) is 

10 decompressed (decoded) . 

The compression/expansion module 412 comprises a data 
compressor 801, a data expander 802, and a data path control 
, section 803. The DMAC 414, that provides controls for 
transmission or reception of image data between the 

15 compression/ expansion module 412 and the memory group 222, 
comprises a DMAC for access to image data (DMAC for images) 
804 and a DMAC for access to code data (DMAC for codes) 805. 
When an access is made to the memory group 222 , a data collision 
does not occur on the DMAC because the image data and the 

20 code data use different channels of the DMAC. 

In Fig. 8A, the compression/ expansion module 412 inputs 
image data from the memory group 222 by the DMAC for images 
804 through the memory control section 407 and the access 
.control section 409. The data compressor 801 removes 

2 5 redundant correlation information between pixels of the image 



data, and performs data compression by coding it. The coded 
data is transferred to the DMAC for codes 805 in the data 
path control section 803 , and stored in the memory group 222 
through the access control section 409 and the memory control 
section 407 . 

In Fig. 8B, the compression/ expansion module 412 inputs 
the coded data from the memory group 222 by the DMAC for codes 
805 through the memory control section 407 and the access 
control section 409. The data expander 802 performs data 
expansion by complementing and decoding correlation 
information between pixels of the coded data. 

The decompressed image data is transferred to the DMAC 
for images 804 in the data path control section 803 , and stored 
in the memory group 222 through the access control section 
409 and the memory control section 407. Further, the 
decompressed image data is transferred, bypassing the DMAC 
for images 804 , to the external bus as required through the 
parallel bus control section 402 , the network control section 
403, or the serial port control section 405. 

Fig. 9 is a block diagram schematically showing a memory 
control section according to this embodiment. The memory 
control section 407 comprises a data buffer 901 that 
temporarily stores image data, a data path control section 
902, an output I/F 903 , a request control section 904 that 
decodes a control command or the like, and an input/output 



control section 905 that controls input/output of data. The 
memory control section 407 further comprises an 
external-memory access control section 906 that controls 
access to an external memory, an input I/F 907 , and a command 
control section 908 that controls commands in the memory 
control section 407. 

The memory control section 407 transmits or receives 
image data between the access control section 409 and the 
memory group 222 . The access control section 409 interfaces 
with each of the DMACs in the manner as explained above, has 
a connection to the system controller 231 by the system I/F 
401, and accepts intervention of the system controller 231 
to the memory group 222 and commands for access controls. 

For access requests of numbers of DMACs and the system 
controller 231 to the memory group 222, the memory control 
section 407 reads image data from the memory group 222 and 
writes image data in the memory group 222. In general, this 
access is capable of being performed discretely. 

On the other hand, when a conflict occurs between a 
plurality of read requests or between a plurality of write 
requests, the memory control section 407 determines 
priorities input from the access control section 409 , accepts 
command control from the system controller 231, switches the 
path between the memory control section 407 and the access 
control section 409, and gives permit to an access with high 




priority . 

At: this time, the DMAC which is not permitted to write 
data in the memory group 222 can not retain data . Accordingly , 
image data can not be input from the external unit to the 
5 memory group 222. In this case, the memory control section 
407 issues a control signal indicating "queuing" to the 
external unit under the control of the system controller 231 , 
and prohibits the operation of data input by any of the units 
to the image-memory access control section 221. 

10 Image data from a DMAC permitted to access the memory 

group 222 or from the system I/F 401 is transferred to the 
memory control section 407 , and a control command of the system 
controller 231 indicating permission given for input of the 
image data is also transferred to the memory control section 

15 407 . The image data is temporarily stored in the data buffer 
901, and the data path control section 902 switches the path 
to the output I/F 903, from which the image data is output 
to the memory group 222 . At this time, the path is controlled 
by decoding the control command from the system I/F 401 in 

20 the request control section 904 to activate (permit) accesses 
from the output I/F 903 to the memory group 222 in the 
input/output control section 905. 

The external-memory access control section 906 
generates a control signal for the memory group 222 in order 

25 to control addresses in the memory group 222 based on the 




control-system data (control command) sent from the DMAC or 
the system controller 231. The external-memory access 
control section 906 then transfers the generated control 
signal and the image data to the memory group 222 , and the 
5 memory group 222 stores the image data. 

On the other hand, the data stored in the memory group 
222 is read by providing address control for the memory group 
222 based on the control-system data from the DMAC permitted 
to access the memory group 222 or from the system controller 
10 231. At this time, the external-memory access control 
section 906 generates a control signal for the memory group 
222 . 

The control signal is then transferred from the 
external -memory access control section 906 to the memory group 

15 222 , image data is read out from the memory group 222, and 
the accessed image data is input into the memory control 
section 407 through the input I/F 907. The input image data 
is temporarily stored in the data buffer 901 by the data path 
control section 902 , and transferred to the channel as a source 

20 of the request via the access control section 409. 

As explained above, the image processor according to 
the present invention integrally manages the overall system 
and can share the memory group with the units without 
occurrence of a conflict between them. Accordingly, it is 

25 possible to make effective use of resources in the system 
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when multifunction is performed and provide optimal controls 
as an overall system. 

Further, the image processor integrates the system 
controller that controls the operation of the overall image 
5 processor, the shared memory group that stores image data, 
and the image-memory access control section that controls 
transmission or reception of image data between the external 
units and the memory group into one module. Therefore, 
alteration of performance for access to the image data (access 

10 to the memory group) can be carried out only by replacing 
the controller unit 301 according to the scale or the 
capability of the apparatus. 

Further, the system control unit controls the image 
memory control unit according to the source of the image data 

15 detected by the source detection unit, and determines a 
transmission order of the image data to the image memory. 
Therefore, the system control unit integrally manages the 
overall system and the image memory can be shared with the 
units without occurrence of a conflict between them. 

2 0 Accordingly , it is possible to obtain an image processor which 
makes effective use of resources in the system when 
multifunction is performed and enables optimal controls as 
an overall system. 

Further, the image memory control unit is connected 

25 via the image data control unit to the image reading unit 

38 



# 



and/or the image processing unit and/or the image writing 
unit, and the image data control unit performs transmission 
or reception of image data between the image memory control 
unit and the image reading unit and/or the image processing 
5 unit and/or the image writing unit . Therefore, adaptability 
of input/output devices to the image memory control can be 
controlled. Accordingly, it is possible to obtain an image 
processor which makes effective use of resources in the system 
when multifunction is performed and enables optimal controls 

10 as an overall system. 

Further, the image memory, the image memory control 
unit, and the system control unit are formed as a discrete 
controller unit. Therefore, it is possible to easily reform 
a controller unit considering the performance of the whole 

15 system. Accordingly, it is possible to obtain an image 
processor which makes effective use of resources in the system 
when multifunction is performed and enables optimal controls 
as an overall system. 

Further , the image memory control unit has a bus control 

20 unit for controlling a bus connected to the units . Therefore , 
it is possible to make easy connection with each of the units , 
and smoothly transmit and receive image data and control 
information. Accordingly, it is possible to obtain an image 
processor which makes effective use of resources in the system 

25 when multifunction is performed and enables optimal controls 
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as an overall system. 

Further, an image data compression unit compresses 
image data, and a volume determination unit determines 
whether the amount of image data is larger than a predetermined 
5 volume. When the volume determination unit determines that 
the image data is larger than the predetermined volume, the 
image memory control unit provides controls so as to transmit 
the image data to the image data compression unit . Therefore , 
efficiency of utilizing the image memory and the bus can be 

O 

y3 10 improved. Accordingly, it is possible to obtain an image 

fU processor which makes effective use of resources in the system 

when multifunction is performed and enables optimal controls 
~— as an overall system. 

f7 Further, an image data expansion unit decompresses 

~ 15 image data, and a compression determination unit determines 

whether the image data has been compressed. When the 
compression determination unit determines that the image data 
has been compressed, the image memory control unit provides 
controls so as to transmit the image data to the image data 
20 expansion unit. Therefore, the processing for image data 
can smoothly be performed in each of the units . Accordingly , 
it is possible to obtain an image processor which makes 
effective use of resources in the system when multifunction 
is performed and enables optimal controls as an overall 
25 system. 




The present, document incorporates by reference the 
entire contents of Japanese priority documents, 11-345356 
filed in Japan on December 3, 1999. 

Although the invention has been described with respect 
to a specific embodiment for a complete and clear disclosure , 
the appended claims are not to be thus limited but are to 
be construed as embodying all modifications and alternative 
constructions that may occur to one skilled in the art which 
fairly fall within the basic teaching herein set forth. 
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